<!--
~  Licensed to the Apache Software Foundation (ASF) under one or more
~  contributor license agreements.  See the NOTICE file distributed with
~  this work for additional information regarding copyright ownership.
~  The ASF licenses this file to You under the Apache License, Version 2.0
~  (the "License"); you may not use this file except in compliance with
~  the License.  You may obtain a copy of the License at
~
~     http://www.apache.org/licenses/LICENSE-2.0
~
~  Unless required by applicable law or agreed to in writing, software
~  distributed under the License is distributed on an "AS IS" BASIS,
~  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
~  See the License for the specific language governing permissions and
~  limitations under the License.
-->

@if (counterListingState$ | async; as counterListingState) {
    @if (isInitialLoading(counterListingState)) {
        <div>
            <ngx-skeleton-loader count="3"></ngx-skeleton-loader>
        </div>
    } @else {
        <div class="flex flex-col h-full gap-y-2">
            @if (currentUser$ | async; as user) {
                <div class="flex-1">
                    <counter-table
                        [counters]="counterListingState.counters"
                        [canModifyCounters]="user.countersPermissions.canWrite"
                        (resetCounter)="resetCounter($event)"
                        (resetAllCounters)="resetAllCounters($event)"></counter-table>
                </div>
            }
            <div class="flex justify-between">
                <div class="text-sm flex items-center gap-x-2">
                    <button mat-icon-button class="primary-icon-button" (click)="refreshCounterListing()">
                        <i class="fa fa-refresh" [class.fa-spin]="counterListingState.status === 'loading'"></i>
                    </button>
                    <div>Last updated:</div>
                    <div class="tertiary-color font-medium">
                        {{ counterListingState.loadedTimestamp }}
                    </div>
                </div>
            </div>
        </div>
    }
}
